<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <script>
        // Promise常用的API-对象方法
        console.dir(Promise) //在控制台查看peomise对象的属性

        // ********************************************************
        function queryData(url){
            return new Promise(function(resolve,reject){
                var xhr = new XMLHttpRequest()
                xhr.onreadystatechange = function(){
                    if(xhr.readyState != 4) return;
                    if(xhr.readyState == 4 && xhr.status == 200) {
                        resolve(xhr.responseText)
                    }else{
                        reject('服务器错误')
                    }
                }
                xhr.open('get',url)
                xhr.send(null)
            })
        }
        var p1 = queryData('http://localhost:3000/a1')
        var p2 = queryData('http://localhost:3000/b1')
        var p3 = queryData('http://localhost:3000/c1')

        // 并发处理三个异步任务
        // Promise.all([p1,p2,p3]).then(function(res){
        //     console.log(res)
        // })
        // Promise.all() 所有的任务完成才会返回结果

        Promise.race([p1,p2,p3]).then(function(res){
            console.log(res)
        })
        // Promise.race() 只得到最先返回的结果
    </script>
</body>
</html>